package com.gjy.algorithm.book.string;

import java.util.Objects;

/**
 * 判断两个字符串是否互为变形词
 * 【题目】给定两个字符串str1和str2，如果str1和str2中出现的字符种类一样且每种字符出现的次数也一样，那
 * 么str1与str2互为变形词。请实现函数判断两个字符串是否互为变形词。
 * 【举例】str1=＂123＂，str2=＂231＂，返回true。str1=＂123＂，str2=＂2331＂，返回false。
 *
 * @author 宫静雨
 * @version 1.0
 * @since 2022-11-28 11:25:45
 */
public class T1 {

    public static void main(String[] args) {
        String s1 = "123";
        String s2 = "231";
        System.out.println(t1(s1, s2));
    }

    public static boolean t1(String s1, String s2) {
        if (Objects.isNull(s1) || Objects.isNull(s2)) {
            return false;
        }
        if (s1.length() != s2.length()) {
            return false;
        }
        char[] c1 = s1.toCharArray();
        char[] c2 = s2.toCharArray();
        int[] ints = new int[256];
        for (char c : c1) {
            ints[c]++;
        }
        for (char c : c2) {
            if (ints[c]-- == 0) {
                return false;
            }
        }
        return true;
    }
}
